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(57) Abstract 

An asynchronous 
transfer mode switch 
employing a plurality of 
physically separate but 
logically connected memory 
modules (40) operates under a 
decentralized pipeline control, 
where the entire switching 
apparatus is devided into 
multiple independent stages 
for their operation in a 
pipeline fashion to increase 
overall switching capacity. 
Incoming ATM cells (1) 
are assigned self-routing 
parameters by a self-routing 
parameter assignment circuit 
(14) using computed new 
parameters for the received 
cells based on the cells 1 
output destination and the 
state of local variables. The 
self-routing parameters are 
attached as an additional 
routing tag to each incoming 
cells for their propagation 
through various stages of the 
switching apparatus. Each 
of the memory modules is 

independent and performs memory management with its local controller. The ATM switching is capable of providing high throughput 
performance under various traffic types with the decentralized switching control, pipeline processing of ATM cells sharing of the global 
buffer space and its ability to realize various buffer sharing schemes. 
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SPECIFICATION 
TITLE OF INVENTION 

OIryEcap^^ pipeline contool and ^ural memory modules for 

CROSS-REFERENCE TO RELATED APPLICATIONS 
Not applicable 

STATEMENT REGARDING FEDERALLY SPONSORED RESEARCH AND DEVELOPMENT 
Not applicable 

REFERENCE TO A MICROFICHE APPENDIX 
Not applicable 

BACKGROUND OF THE INVENTION 
1 . Field of the I nvention 

This invention relates to high capacity packet switching apparatus, in general and Asynchronous Transfer 
Mode (ATM) cell switching apparatus, in particular which is typically used for high speed multimedia 
networking communications. More particularly, this invention is directed towards decentralized and 
pipeline control based ATM switching apparatus and method to enable high capacity switching. 



2. Prior Art 

Besides its best possible delay-throughput performance, ATM switching systems employing shared buffers 
have also been known in the art to incur the lowest cell-loss rate compared to that of the ATM switches 
employing input or output buffering strategies. However, a typical design of a large shared-buffer based 
ATM switching system has been severely restricted by the bottleneck created by high memory bandwidth 
requirements, segregation of the buffer space and centralized buffer control bottleneck which causes the 
switch performance to degrade as the switch grows in size, in order to preserve its ability to provide for 
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the low cell-loss rate for a given buffer size, an ATM switching network design should attempt to provide 
for global buffer sharing among all its inputs and output lines, provide memory sharing schemes to allow 
fair sharing of a common memory space under different traffic type and alleviate performance bottleneck 
caused by centralized control. 

A traditional approach to design a large size shared-buffer based ATM switching systems has been to first 
design a feasible size shared-buffer ATM switching modules and then interconnect plurality of such 
modules in some fashion to build a large size switching system. Some of the previously used methods and 
schemes to build large size shared-buffer based ATM switch can be categorized as follows: 

The Multistage Interconnection Network (MIN) approach: According to this general scheme, a multistage 
interconnection network is used to build a large size shared-buffer based switching system with a small 
size, shared-buffer switching elements deployed at each node of the interconnection network [SAKURAI 
Y., et al, "Large-Scale ATM Multistage Switching Network with Shared Buffer Memory Switches," IEEE 
Communication, January 1991.]. This general scheme of switch growth is known to cause degradation in 
performance of a shared-buffer architecture as the switch grows in size. Degradation in cell-loss and 
throughput performance result mainly from internal link conflicts, output blocking and incomplete buffer 
sharing due to separation of memory space among plurality of modules. Furthermore, it is obvious that 
this approach does not allow global sharing of the employed buffer space among all of its input-output 
ports. Because of separation of buffer space, not all output lines can share the entire buffer space of the 
switch. Under unbalanced traffic it is possible for some switch buffers to overflow while other switch 
buffers being under utilized. 

Growable switch approach [ENG K. Y. et al, **A Growable Packet (ATM) Switch Architecture: Design, 
Principles and Applications," IEEE Transactions on Communications, February 1992] : Unlike the 
Multistage Interconnection network approach mentioned above, in growable switch approach, a plurality of 
shared-buffer based switches are organized in a single stage preceded by a bufferless [ N x (m/n)N ] 
interconnection network. Although this approach succeeds in providing an improved overall performance, 
compared to the general MIN approach, it does not allow global sharing of memory space among ail its 
inputs and outputs. It is known in the art that this scheme does not provide best buffer-utilization as it is 
possible for a buffer belonging to a group of output ports to overflow under unbalanced or bursty traffic 
conditions while other buffers belonging to other output ports being empty. 

The Multiple Shared Memory (MSM) approach [WEI S.X. et al, "On the Multiple Memory Module 
Approach to ATM Switching," IEEE INFOCOM, 1992 ]: Unlike the previous two approaches mentioned 
above, this approach allows for the global sharing of the employed buffer space. However, MSM switch 
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approach employ centralized control of the switching system consisting of plurality of memory modules. 
Use of centralized control can become a performance bottleneck if the switch grows in size. Furthermore, 
in MSM switch approach, the conditions for the best possible delay-throughput performance has been 
derived under the assumption of infinite buffer space in the switching system. In reality, a buffer space 
tends to be finite and a realistic switching algorithm must accommodate for the constraints imposed by the 
finiteness of the buffer space in an ATM switching system. A finite buffer space results into cell-loss, and 
in the absence of an appropriate buffer sharing scheme, it results into performance degradation [KAMOUN 
F. and KLEIN ROCK L., "Analysis of Shared Finite Storage in a Computer Network Node Environment 
Under General Traffic Conditions," IEEE Transactions on Communications, July 1980 ]. A switching 
scheme which provides for a global sharing of the buffer space may not necessarily provide for best 
possible delay-throughput performance if the shared-buffer space tends to be finite. In order to provide for 
best possible performance with a finite common buffer space, a switching scheme should also be able to 
enforce various buffer sharing schemes to provide fair sharing of finite buffer space under various traffic 
types. 

In [OSHIMA et al., "A New ATM Switch Architecture based on STS-Type Shared Buffering and Its 
Implementation," ISS 1992], the proposed shared multibuffer (SMB) based ATM switch design also 
provide a complete sharing of memory space among all its input and output ports. The shared multibuffer 
based ATM switch is also disclosed in recently assigned U.S. Patent Number 5,649,217 to Yamanaka et al. 
The shared multibuffer switch of Yamanaka et al., schematically shown in FIG. 1, uses a centralized 
controller to centrally control and manage a plurality of buffers and its write and read operations for each 
incoming and outgoing cells, centrally manage and update a plurality of address queues for each incoming 
and outgoing cells, centrally provide instructions to incoming and outgoing spatial switch on how to 
provide routing of ATM cells corresponding to each of the input and output lines, and centrally coordinate 
the operation of its various components to realize overall switching function of the switching apparatus. 
The disadvantage of this approach is that the use of centralized controller can become a performance 
bottleneck as the switch grows in size (i.e. the input and output lines increase in number and/or speed). 
Growth in the size of the switch and hence the number of input and output lines would require the 
centralized controller to perform increased number of tasks (such as write and read operations for ATM 
cells, storage and management of information in address queues in the central controller) for increased 
number of memory modules and input/output lines in a fixed switching time-slot. Similarly, as the switch 
grows in size, the central controller will need to provide increased number of routing instructions to 
incoming line spatial switch and outgoing line spatial switch for increased number of input and output lines 
in a fixed switching time-slot. Overall, the centralized controller will have to do increased number of all 
centralized control fiinctions and memory operations described therein, in a fixed switching time-slot 
(which is usually smaller than the interarrival time of two consecutive cells). It is obvious that the 
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centralized controller used by Yamanaka et al., as disclosed in U.S. Patent Number 5,649,217 can easily 
become a bottleneck to the switch performance as the switch grows in size or switching capacity. 

BRIEF SUMMARY OF THE INVENTION 

The above mentioned problems, and in particular the bottleneck problem caused by the use of centralized 
controller (as described in the disclosed invention U.S. Pat. No. 5,649,217) are removed by the switching 
method and apparatus of the disclosed invention. The disclosed switching method and the apparatus (i) 
alleviate the need for a centralized buffer controller and hence remove the performance bottleneck resulting 
from the use of a centralized controller, (ii) provide a way to partition overall switching function in to 
multiple independent switching operations such that the independent operations can be performed in 
parallel, (iii) partition the switching apparatus in multiple independent stages with each stage running one 
of the above mentioned independent switching operation, (iv) operate multiple independent stages in a 
pipeline fashion in order to enhance parallelism while processing the incoming ATM cells for switching 
purposes, (v) provide decentralized control such that multiple independent stages perform their switching 
operation based on the information available locally and they do not have to depend on any central 
controller to provide centrally updated global variables, switching or buffer management related 
instructions, (vi) facilitate an efficient sharing of a finite buffer space among all the switch inputs and 
outputs (vii) provide various memory sharing schemes to allow for fair sharing of a common memory 
space under various traffic types. 

A switching method is also disclosed according to which the entire memory space of the switching 
apparatus is depicted as multidimensional globally shared buffer space. The coordinates of the space help 
identify a proper location for incoming cells in the global buffer space so that they can be switched with 
best possible delay throughput performance. According to this method, each incoming cells are assigned a 
self-routing parameters in the form of an additional self-routing tag for their self propagation through 
various pipeline stages of the switching apparatus. As the ATM cells pass through different stages of the 
switching apparatus, the corresponding switching functions are locally performed by each stage on the 
received ATM cells. Each stage uses the value of the self-routing parameters in the received cells while 
performing its local switching operations. Because of the pipeline processing of ATM cells, the switching 
capacity of the system is enhanced considerably. 

Memory modules and resulting global buffer space are not controlled and managed by any centralized 
buffer controller. Each memory modules are independent and use their local memory controllers to 
perform WRITE and READ operations for the received ATM cells and also perform related memory 
management. The local memory controllers work independently of each other and still help manage and 
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control the globally shared buffer space of the switching apparatus. For write operation, local memory 
controllers use the self-routing parameters of received cells to determine the write address for the cells and 
write them to respective location in their memory modules. For read operation, the local memory 
controllers use the disclosed switching method to generate their read addresses to read cells from their 
memory modules. 

The disclosed switching system facilitate an efficient sharing of a finite buffer space among all the switch 
inputs and outputs. The proposed switching system can provide complete buffer sharing, partial buffer 
sharing and complete partitioning of the entire buffer space employed in the system. Because of its ability 
to operate in a decentralized pipeline fashion the disclosed switching method can be used to design a large 
size shared buffer based ATM switching system. Because of its ability to realize various buffer sharing 
schemes, the disclosed switching method and apparatus can be designed for high throughput performance 
under various traffic types. 



BRIEF DESCRIPTION OF THE DRAWINGS 

FIG. 1 is a schematic diagram showing the ATM switching architecture having centralized controller and 
plural buffer memories disclosed in U.S. patent number 5,649,217; 

FIG. 2 is a schematic diagram showing the ATM switching architecture having decentralized pipeline 
control and plural buffer memories according to a preferred embodiment of the present invention; 

FIG. 3 is an illustration of multidimensional global buffer space which includes all the ATM cell memory 
locations in ail the memory modules employed by the switching system, according the present invention; 

FIG. 4 is a flow diagram of the portion of the disclosed method that provide underlying switching 
functions for the switching apparatus, according to this invention; 

FIG. 5 illustrates a flow diagram of the portion of the disclosed method that computes and assigns self- 
routing parameters to the incoming ATM cells in the switching apparatus, according to this invention; 

FIG. 6 illustrates a block diagram of the self-routing parameter assignment circuit using the self-routing 
parameter assignment method; 

FIG. 7 is a block diagram showing the components of the memory controller using the disclosed 
switching method, according to the present invention; 

FIG. 8 illustrates flow diagrams for memory write and memory read operations performed each cycle by 
the memory controller of FIG. 7; 

FIG. 9 shows the time chart for the decentralized pipeline operation of the various stages of the 
switching system; 
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FIG. 10 shows an instance of eight cycles of incoming cells input to an exemplary 4x4 switching 
apparatus, according to the disclosed switching system and method in the present invention; 

FIG. 11 shows an schematic diagram of a 4x4 ATM switching apparatus employing decentralized 
pipeline control based switching method disclosed according to an exemplary embodiment of the present 
invention; 

FIG. 12 illustrates decentralized pipeline operation of multiple stages while performing the switching 
operation on eight cycles of incoming ATM cells, according to the preferred embodiment of the present 
invention; 

FIG. 13 illustrates the content of various counters and tables after the switching functions performed by 
the first pipeline stage in the first pipeline cycle of the 4x4 ATM switching apparatus according to 
exemplary embodiment of the present invention; 

FIGS. 14-1, 14-2 illustrate the switching functions performed for the received cells in the second pipeline 
cycle by the first and second pipeline stages of the switching apparatus according to an exemplary 
embodiment of the present invention; 

FIGS. 15-1, 15-2 and 15-3 illustrate the switching functions performed for the received cells in the third 
pipeline cycle by the first, second and third pipeline stages of the switching apparatus according to an 
exemplary embodiment of the present invention; 

FIGS. 16-1, 16-2,16-3 and 16-4 illustrate the switching functions performed for the received cells in the 
fourth pipeline cycle by the first, second, third and fourth pipeline stages of the switching apparatus 
according to an exemplary embodiment of the present invention; 

FIGS. 17-1, 17-2, 17-3, 17-4 and 17-5 illustrate the switching functions performed for the received cells 
in the fifth pipeline cycle by the first, second, third, fourth and fifth pipeline stages of the switching 
apparatus according to an exemplary embodiment of the present invention; 

FIGS. 18-1, 18-2, 18-3, 18-4 and 18-5 illustrate the switching functions performed for the received cells 
in the sixth pipeline cycle by the first, second, third, fourth and fifth pipeline stages of the switching 
apparatus according to an exemplary embodiment of the present invention; 

FIGS. 19-1, 19-2, 19-3, 19-4 and 19-5 illustrate the switching functions performed for the received cells 
in the seventh pipeline cycle by the first, second, third, fourth and fifth pipeline stages of the switching 
apparatus according to an exemplary embodiment of the present invention; 

FIGS. 20-1 , 20-2, 20-3, 20-4 and 20-5 illustrate the switching functions performed for the received cells 
in the eighth pipeline cycle by the first, second, third, fourth and fifth pipeline stages of the switching 
apparatus according to an exemplary embodiment of the present invention; 

FIGS. 21-1, 21-2, 21-3 and 21-4 illustrate the switching functions performed for the received cells in the 
ninth pipeline cycle by the second, third, fourth and fifth pipeline stages of the switching apparatus 
according to an exemplary embodiment of the present invention; 
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FIGS. 22-1, 22-2 and 22-3 illustrate the switching functions performed for the received cells in the tenth 
pipeline cycle by the third, fourth and fifth pipeline stages of the switching apparatus according to an 
exemplary embodiment of the present invention; 

FIGS. 23-1 and 23-2 illustrate the switching functions performed for the received cells in the eleventh 
pipeline cycle by the fourth and fifth pipeline stages of the switching apparatus according to an exemplary 
embodiment of the present invention; 

FIG. 24 illustrates the switching functions performed for the received cells in the twelfth pipeline cycle 
by the fifth pipeline stage of the switching apparatus according to an exemplary embodiment of the present 
invention; 

FIG. 25 shows input and output time relation for the previous stream of cell arrivals for 8 pipeline cycles 
and the switch operation for up to 22 pipeline cycles until all the cells resident in the global buffer space 
are output. The update process for the sliding-window counter belonging to the read stage is also shown! 

FIG. 26 illustrates the occupancy of multidimensional global buffer space for cells input to the switching 
apparatus for 12 consecutive cycles, according to disclosed sliding-window switching method of the 
present invention; 

FIG. 27 shows input and output time relation for a stream of incoming cells for 1 2 pipeline cycles and the 
status of the sliding-window counter in the read stage, according to the exemplary embodiment of the 
switching apparatus and method of the present invention; and 

FIG. 28 illustrates operation of the switch under an unbalanced traffic where a multiple stream of 
incoming cells are destined to one particular output port. Under such traffic conditions, the process of 
queue control inside the globally shared buffer space is shown. The occupancy of multidimensional global 
buffer space and an instance of cell discard for cells input to the switching apparatus for 16 consecutive 
cycles, according to the switching method of the disclosed invention, is also shown. 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS 

Referring now in specific detail to the drawings, with reference numerals identifying similar or identical 
elements the preferred embodiment of the present invention will be described. FIG. 2 shows the overall 
architecture of the ATM switching system as an example of the packet switching apparatus employing 
decentralized pipeline control of memory and switching functions according to this invention. In FIG. 2, 

the input lines are denoted by 1„ 1, l„ and the output lines are denoted 2„ 2„ ,...2 r . Input lines carry 

the incoming ATM cells and the output lines carry the outgoing ATM cells after being switched to their 
output destination by the ATM switching system of FIG. 2. In this switching system, no central buffer 
controller is used to centrally store addresses of cell headers in the address queues or to keep track of all the 
read and write operations for all the memory modules or to coordinate corresponding buffer management 
operations or to provide related control instructions to different components of the switching apparatus. 
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The disclosed switching system uses a decentralized control according to which each incoming ATM cells 
are assigned a self-routing tag. The self-routing tags allow the ATM cells to independently (means not 
under the instruction of a central controller) proceed through the different stages of the switching apparatus 
and enable various switching functions to take place at different stages based on the information stored in 
the self-routing tags of the cells. The incoming cells are processed by header processing circuits 10, , 10 2 , 
... 10 o for extraction of the output line destination address denoted by d. The destination address of 
incoming cells are forwarded to a self-routing parameter assignment circuit 14. The self-routing parameter 
assignment circuit 14 uses the output destination information d and a parameter assignment method to 
provide a set of self-routing parameters Qj t k) to each incoming ATM cells. The self-routing parameters 
(ij,k) which are obtained by the self-routing parameter assignment circuit 14, are then attached as a self- 
routing tag to the incoming ATM cells by the header processing circuits 10, , 10 2 , ... 10 R . Hereinafter, each 
incoming cells use the attached self-routing tag (ij,k) to propagate independently through various stages of 
the disclosed ATM switching apparatus of FIG. 2. The parameter i in a cell's self-routing tag designate the 
memory module that the cell will be stored in; the parameter j in a cell's self-routing tag designate the 
memory-location in the i* memory module that the cell will be stored to; the parameter k in the self-routing 
tag designate an additional parameter called the scan plane which help decide when a given ATM cell is to 
be read out of the memory for output purposes. The input interconnection network 20 uses the parameter / 
of the routing tag of an incoming ATM cell to route the cell on a given input line to its /* output line which 
in turn is connected to the respective /* memory module. Input lines of the interconnection network 20 
connects itself to the header processing circuits 10„ 10 2 , .... 10 ro while the output lines of the 
interconnection network 20 connects itself with the memory modules of the switching apparatus. Input 
modules 30„ 30 2i ... 30 m are used corresponding to each one of the memory modules 40 t ,'40 2 , .... 40 m . 
The input modules 30„ 30 2 , ... 30 w can be used for multiple purposes however, the primary purpose of the 
input modules 30 lf 30 2 , ... 30 m is to hold a received cell for a predetermined time period before being 
stored in the respective memory modules. Another function of modules 30„ 30 zt „, 30 m is to hold a 
received ATM cell and provide the parameters j and k information from the cell's self-routing tag to 
memory controllers 50„ 50 2) ... 50 m . The memory controllers use the parameter j to write the received 
ATM cell in the j * memory-location of the corresponding memory modules 40 t , 40 2 , .... 40 m . 
Corresponding to each memory controller 50„ 50 2 , .... 50 m there is one Output Scan Array (OSA) each 
with a locations. The/ 1 location of the Output Scan Array (OSA) holds the scan value of a received ATM 
cell stored in the corresponding / location of its memory module. OSA of each memory controller is 
updated at the time of Write and Read of ATM cells to and from the respective locations in the memory 
modules. During the Write cycle of an incoming cell to / memory location in a given memory module /, 
the scan-plane value (A) of the received cell is stored in the corresponding/ 1 location in the Output Scan 
Array (OSA) of the corresponding memory controller. During the Read cycle of a cell from the / location 
of a memory module, the corresponding / location in the Output Scan Array (OSA) is set to 0 to indicate 
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empty memory-location in the corresponding memory module. During the ATM cell read cycle, the ATM 
cells are output from parallel and independent memory modules 40„ 40„ .... 40„ and are finally routed to 

respective output destinations 2„ 2, 2 r by the output interconnection network 60. The output 

interconnection network 60 makes use of the output port destination information d stored in a cell's header 

to route each cell to final output destination 2„ 2, 2 r . In the exemplary embodiment of the disclosed 

ATM switching apparatus of Fig 2, the final output line destination information •«/■ can also be seen as a 
part of the routing tag, with the difference that instead of residing in the routing tag, the destination 
information *d' resides in the header of each incoming cells. 

The ATM switching apparatus of the disclosed invention makes use of a new switching method called the 
Sliding-Window ATM switching method . The following section describe the underlying switching 
functions of the disclosed invention of the Sliding-Window ATM switching method. 



THE SLIDING-WINDOW ATM SWITCHING METHOD 

According to the disclosed Sliding-Window ATM switching method, the entire buffer space which 

includes all the ATM cell memory locations in all of the memory modules 40„ 40, 40„ , is represented 

as a three dimensional space {ij,k) and is shown in F1G.3. The total buffer space of the switching system 
of FIG.2 is also called shared buffer space or global buffer space as multiple input and output lines can 
have access to memory locations belonging to any of the memory modules 40„ 40 M .... 40 B employed in 
the exemplary embodiment of switching apparatus of FIG. 2. In the sliding-window switching method, the 
ATM memory locations in the global buffer space are represented by state (ij,k) where 

coordinate represent the memory-module; / =[/.. «] , where m is the number of memory modules 40„ 
40„ .... 40„, employed in the switching apparatus; 

/h coordinate represent the output-slot vector (osv); j = [/ .. crj , where a is the number of ATM cell 
memory locations in the memory modules; 

coordinate represent the scan-plane (sp) value ;*-[/.. p ]. where p is used as an upper bound that 
designate the number of times, compared to the scan length a, that an output queue's length can grow up 
to. 

As shown in FIG. 3, The (ij )* p i ane 0 f the buffer space is called the scan plane and is designated by 1S„ 

r 

15„ .... 15 p . Each scan plane is divided into a output-slot-vectors (OSVs) . Each OSV consists of a m 
number of consecutive slots (also called memory slot), where m is the number of memory modules 40„ 
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40„ „„ 40 w employed in the system. The output-slot vector (OSV) j represent a group of y* ATM cell 
memory locations in the m number of employed memory modules. The sliding-window 18 (shown in 
FIG.3) is a pointer to a group of cells forming the output-slot vectors (OSV) in the memory space and it 
advances by one OSV upon completion of every switch cycle on a given scan plane. Input and output of 
ATM cells take place with respect to the current location of the sliding-window and the last cell admitted to 
the multidimensional global buffer space. The location of the sliding window (SW) 18 in the global buffer 
space is described by two variables indicated by (i) SW.osv (interchangeably used with SW.J) and (ii) 
SW.sp (interchangeable used with SW.k). For example, in FIG. 3, the sliding-window 18 is a pointer to the 
OSV =j = 5 and is traversing on the second scan plane 15 2 having k = 2. For such a state of the sliding- 
window in the above example SW.osv « SWJ = 5 and SW.sp = SW.k « 2. The symbol 'osv* and *sp' denote 
output slot vector and scan plane and are interchangeably used, in this description, with j and k variables 
respectively. The variable SW.sp (which is interchangeably used with SW.k ) holds an integer value 
which is incremented by one on the completion of sliding-window's traversal on each scan-plane. 
Similarly, the variable SW.osv (which is interchangeably used with SWJ ) holds an integer value which is 
incremented by one on the completion of sliding-window's traversal of a given output slot vector (OSV). 
To keep the SW.sp and SW.osv variables from becoming unbounded, the modulus of the scan-plane 
variable with a predetermined upper bound value (p ) of the scan-plane and the modulus of the OSV 
variable with a predetermined upper bound value a of the output slot vector (OSV) is taken. The Sliding- 
Window 18 of FIG. 3 traverses the entire global buffer space by traversing cr output slot vectors (OSVs) on 
all of the employed scan-planes 15 ( , 15 2) 15p in a circular fashion. For an incoming ATM cell destined 
to output line d of the switching apparatus, the assignment of a memory-slot (/ ) of an OSV(/ ) on a scan- 
plane (A ) is dependent on the length of its output queue, Q d in the global buffer space and on the current 
location of the sliding-window 18. The successive cells of an output queue Q d occupy successive OSVs 
with one of its cells in one OSV on a given scan-plane. When the queue Q d exceeds the a* OSV on one 
scan-plane, it starts acquiring slots of the OSVs of the next scan plane. Thus an output queue can grow up 
to a length of <r on a given scan plane. o\ the number of OSVs on one scan plane is also called the scan- 
length of the employed global buffer space and is equal to number of ATM cell locations in a given 
memory module. The number of scan planes 15„ 15 2 , 15p to be employed in the switching system is 
determined by the maximum queue length ( « p.a) allowed for an output port. If the maximum length of 
an output queue is allowed to be p.a then p scan planes are employed in the system, as an output queue 
can grow only up to a length of o* on a given scan plane. As an example, if the maximum length for 
output queues is allowed to be 2048 ATM cells in the global buffer space (i.e. p.a= 2048) of the ATM 
switching apparatus; and if the number of ATM cell memory locations in memory modules 40„ 40 2 , .... 
40 m is equal to 512 ATM cells (i.e. a ~ 512) then the number of scan planes to be employed in the 
switching apparatus = p = (2048 / 5 12) = 4. In effect, the number of scan-planes i.e. p , employed in the 
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ATM switching system of FIG.2, controls the allowed maximum number of cells waiting for an output 
port (i.e. maximum queue length) inside the global buffer space which includes all the ATM cell memory 
locations in all of the memory modules 40„ 40„ .... 40 m . 

The concept of traversal of the sliding-window through the entire buffer space and its relation to the switch 
cycle and the switching operation is depicted by the flow-chart of FIG.4. The traversal of the sliding- 
window through multidimensional global memory space depicts the way the sliding-window pointer is 
updated along with the switching functions performed every switch cycle. In flow chart of FIG. 4, step 
400 indicate beginning of the switch operation. Step 402 shows the initial value of the variables SW.osv 
and SW.sp , indicating initial location of the sliding-window in the global buffer space. On the onset of the 
switching operation, as shown in step 404, various switching functions are performed on the incoming 
cells. The switching functions may include one or more of the following operations: read destination 
addresses from headers of the incoming cells, update counters and tables, attach a new self-routing tag to 
the cells, write cells to the memory modules, read cells from memory modules etc.. Upon completion of 
the switching functions, the system waits in step 406 for start of a new cycle. In the case no cells received 
or no switching functions to be performed in step 404, the system justs goes to the step 406 and wait for a 
new cycle to start. In the beginning of every new cycle, counters and variables are updated in step 408 to 
account for changes, if any, in the previous switch cycle. In the new switch cycle, the sliding-window is 
advanced to the next OSV in step 410 with its scan plane variable i.e. SW.sp being unchanged. Step 412 
examines if the sliding window has already traversed all the OSV on a given scan plane and if it needs to 
start traversing the new scan plane. If the sliding window has not traversed all the OSV on a given scan 
plane then the flow loops back to step 404 to perform new switching function corresponding to new value 
to the sliding-window pointer. If the sliding-window has traversed all OSVs on a given scan plane and is 
starting over with the initial OSV of 1 (as indicated by the initial value of 1 for OSV, in step 412) , then 
scan plane variable of the sliding window i.e. SW.sp is updated in step 414 to indicate the beginning of its 
traversal on the successive scan plane. With the updated location of the sliding window denoted by the 
variables SW.osv and SW.sp, the new switching functions are performed and it is denoted by the control 
flow loop back to step 404. Upon completion of the switching functions in step 404, the system again 
waits for a new cycle in step 406. The underlying switching function of the sliding-window method at step 
404 is that during the input phase of each switch cycle, incoming ATM cells are assigned memory 
locations within the global buffer space with the help of self-routing parameter assignment circuit 14 and 
during the output phase of each switch cycle, all the ATM cells belonging to output-slot vector (OSV), 
pointed by the sliding window (SW) 18 on a given scan-plane, are output. Output phase of the switch 
which consists of reading out the cells from memory modules and their routing through the output 
interconnection network, marks the end of one switch cycle. The sliding window (SW) 18, as shown in 
FIG.3, cyclically scans the entire buffer space by traversing all of the a OSVs on each scan-plane (sp) of 
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the global buffer space and as shown in FIG.4, switching functions are performed corresponding to every 
state the sliding-window during its traversal of the multidimensional global memory space. 

In the exemplary embodiment of the present invention, the switching of ATM cells by the switching 
apparatus of F1G.2, is partitioned into multiple independent operations. Namely, the self-routing parameter 
assignment operation, routing of cells to memory modules using input interconnection network, ATM- 
cells' memory WRITE operation , ATM-cells' memory READ operation, and routing of cells obtained 
from memory modules to the destined output lines using output interconnection network. 

SELF-ROUTING PARAMETERS (ij.k) ASSIGNMENT 

As mentioned earlier, the assignment of self-routing parameters (ij,k) to the incoming cells is achieved by 
the parameter assignment circuits 14 . An additional routing-tag carrying the self-routing parameters 
Oj.k) are attached to each incoming ATM cells. The self-routing parameter help ATM cells to self 
propagate through the switching apparatus of FIG.2. The self-routing parameter also help achieve 
independence from the use of any centralized buffer controller and hence facilitate decentralized and 
pipeline control for faster switching operations. 

Determination of self-routing parameters ( /, j, k ) by an exemplary assignment circuit 14 for an incoming 
ATM cell is shown by the flow chart of FIG. 5. The symbols used therein are described as follows: 

• d is the switching system's output-port 2„ 2 2 , .... 2 r destination which resides in the header portion 
of the incoming ATM-cell; In the exemplary embodiment of switching apparatus of FIG.2, d= {1,2, 
...r}. 

• id is the assigned output-slot vector (OSV) in the global buffer space for an incoming ATM ceil 
destined to output port d. 

• kd denotes the assigned value of the scan-plane in the global buffer space for an incoming ATM cell 
destined to output port d. 

• id is the assigned memory slot in the assigned OSV, Jd above. i 6 designates one of memory 
modules 40„ 40 2 , .... 40„. 
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o is the maximum number of output slot vector (OSV) present on the scan planes of the global buffer 
space. 

• p is the maximum number of scan-planes IS,, 1 5, 15, employed in the global buffer space. 

• X is the set of all ATM cells input during a given switch cycle, 0 <= | X | <= n, where n is the 
number of input ports 1„ 1 2 , .... 1„. 

The assignment circuit 14 and the flow diagram of FIG.5 use a set of counters and tables (shown in FIG.6 ) 
to facilitate the assignment of self-routing parameters. The self-routing parameter assignment circuit 14, in 
this exemplary embodiment of the ATM switching apparatus, uses two separate processors FIG. 6. The 
first processor 600 receives the destination address of the incoming cells from header processing circuits 
10„ I0„ .... 10, and use steps 506 to 524 of the flow chart in FIG.5 to assign j and * parameters. Once the 
j and k values are determined, processor I sends j and k parameters to another processor 650 for 
determination of the parameter /. While processor 2 works to find #* parameter for a cell as shown in step 
526 of FIG.5 flow-chart, the processor 1 starts working in parallel on determination ofy and k parameters 
for the next cell. In effect, processor I 600 and processor 2 650 of FIG. 6 work in parallel to determine j.k 
parameters and the corresponding r* parameter for incoming cells in a given cycle. The counters 610 and 
670, called sliding-window counter, hold the current location for the sliding-window pointer in global 
buffer space. With every switch cycle, the sliding-window counters 610 and 670 of processors 600 and 650 
update its value independently according to the sliding-window traversal concept of FIG.4. The relation of 
update of the sliding-window counter values with each switch cycle and associated switching functions is 
shown in the flow chart of FIG.4. In FIG.6, the sliding-window counters 610 and 670 specify variable 
SW.osv which designate the OSV that holds the current location of the sliding window in global memory 
space in a given switch cycle. The counters 610 and 670 also specify variable SW.sp which designate the 
scan-plane that holds traversal of the sliding-window in a given switch cycle. The queue length counter 

(QLC) 620 holds the length of the queue of cells destined to respective output port 2„ 2, 2, 

destinations. The respective queue length is designated by Q d where d= 1,2, ... r. The counter 630, called 
Last cell counter (LLC), holds the value of scan plane and output slot vector of the last cells entered in the 
global buffer space for all the output port 2„ 2„ .... 2 r destinations. The variable (LC.^d designate the 
OSV-value assigned to the last-cell destined to the output rfand the variable (LC.*) d designate the scan- 
plane value assigned to the last-cell destined to the output d. A two dimensional array 660, also called 
scan table (ST), is used for determination of parameter i by the processor 2 650 of FIG.6. The slots of the 
scan table are designated by ST(y) wherein / and j denote the rows and columns of the scan table 
respectively. The parameter / can take value from 1 ... to m, where m is the number of memory modules 
40„ 40„ .... 40 m employed in the exemplary switching system of FIG.2. The parameter j can take value 
from 1 ... to cr, where o is the number of ATM memory locations in the employed memory modules 40„ 
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40 2l .... 40,,, . The content of a slot of the scan table i.e. ST(/,/) holds only the value of the scan variable k 
belonging to the ATM cell which is stored in the j * location of the i* memory module in global buffer 
space. Hence ST(iJ) « *, where k > 0, indicate that the location of the /* memory module hold a valid 
ATM cell whose scan-plane value is k. Whereas, ST(iJ) = 0 indicate that the / h location of the / 1h memory 
module in the global buffer space is empty and do not hold a valid ATM cell. 

The flow chart in FIG.5 shows the assignment process for the self-routing parameter (ij t k) to the incoming 
ATM cells. 

In these steps, the output slot vector (osv) and scan-plane value (sp ) are also represented by j and k 
variables interchangeably. Q d represent the queue length for output d. X represent the set of ATM cells 
input to the switch during a given switch cycle. j x ->d °r just jd represent the OSV assigned to the cell x 
destined to output d. k x .>d or just k<j represent the scan-plane value assigned to the cell x destined to 
output d. 

Step 500 shows the initial state where X ceils are input in a given cycle through the incoming ports 1„ l 2 , 
— 1. . Step 502 shows removal of a cell x from the non-empty set of input cells Xt = {x(t) 1 1= current 
cycle} for the purpose of determining output port d for the chosen ATM-cell x in step 504. The steps 502- 
504 can also be performed by the header processing circuits. The determination of the output port d is 
straight forward, as the incoming ATM cell header already contains the information about its output port 
destination. The output port destination information d, and the QLC counter 620 in FIG.6 helps determine 
the queue length Qd for the cell x in step 506 of the flow chart in Fig 5. Step 506 also increments the 
value of Qd to take into account the new arrival. According to step 508, if ( Qd > per ) then cell x is 
dropped and Qd value is decrement by one in step 510 and the assignment process loops back to step 502 

to process another cell input in that cycle. Here p.cr is a predetermined upper limit imposed on the length 
of a queue inside the global buffer space. 

In step 512 the queue length of a given destination port is compared. If Qd = 1 then it means it is the only 
cell for the given destination port in the global buffer space and it need not wait inside the buffer as 
there are no other cells for that destination port waiting for its turn to be read out. In such a case, step 514 
is followed according to which the OSV and the scan plane value of the current location of the sliding 
window counter 610 is assigned as/ and k parameters for the incoming cells in step 514 of FIG.5 i.e. {jd 
= (LC.yjrf = SW.osv ; kd = (LC.k)d » SW.sp\ ) . If the value of Qd > 1 then it means that the queue has 
been building up for the cells destined to output port d and the steps 516, 518, 520 and 522 are used along 
with the last cell counter 630 (FIG. 6) to assign the j and k parameters to the incoming cells. According to 
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step S16 { j d - (LC/)rfmod a+\ } which means consecutive OSV i.e. OSV next to the given destination's 
last cell's OSV is assigned as they variable for the incoming ATM cell. To assign k variable, the assigned 
OSV j d to the incoming cell destined to output port d, is first examined in step 518. if j d =\as shown in 
step 518 then it means that the assigned output slot vector is on a new scan-plane and the scan-plane value 
to be assigned to the incoming cell is increment by 1, in step 522 as k d = (LC.k) d mod p +1. On the 
contrary, if the value of the assigned^ to the incoming cell is not equal to I then it means that the 
assigned output slot vector is on the same scan plane as the last cell assigned for that destination's output 
queue and same value of the LCk from the counter 630 is assigned as the k parameter for the incoming cell 
in step 520 of the flow chart of FIG. 5. By now in the flow chart of FIG. 5, an incoming cell destined to d, 
has obtained two out of its three routing parameters i.e. for OSV as j d and the scan plane k d . 

Step 524 in the flow chart of FIG. 5 indicate that once they and k parameters are determined by processorl 
600 of FIG. 6 then they are sent to another special purpose processor 650 of FIG.6 for the determination 
of its / parameter with the help of a scan table 660. Processorl 640 starts processing to determine next 
cells, and k parameter (as shown by the loop back in step 528 of the flow chart in FIG. 5) in parallel with 
the processor 680 which is working to find the i parameter (as shown by step 526 of the flow chart in FIG. 
5) for the previous ATM cell. While assigning / * parameter, attempt is made by the processor 2 650 to 
assign different /* parameter (i.e. different rows in the scan table 660) to the cells belonging to the same 
input cycle so that they can be routed by the input interconnection network 20 to respective memory 
modules 40„ 40„ .... 40. in parallel with smaller delay. Assignment of different /* parameter to the cells 
belonging to same input cycle enhance the parallelism while routing the cells to different memory modules. 
One way to assure the assignment of different memory modules is to employ sufficient number of memory 
modules in the switching apparatus so that the sufficient number of memory slots are always available in 
an assigned output slot vector. The minimum number of memory modules to be employed in the system 
also depend on the maximum length of queue allowed in the switching apparatus and is discussed in detail 
in a later section. 

Once ATM cells get their self-routing tag {ij.k) from the parameter assignment circuit 14 , the ATM cells, 
thereafter, are self routed through the various stages of the switching apparatus of FIG. 2. 

INPUT INTERCONNECTION NETWORK 

The input interconnection network examines the «< K parameter of the routing tag of received ATM cells and 
provide routing of the ATM cell to its /* output line which is connected to the /* memory module. 
Mapping of cells from its input lines to its output lines of the input interconnection network 20 can be 
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achieved in very many ways and operations of such interconnection networks are well known in the art. 
One way to provide the needed input and output mapping function is to use a processor local to the 
interconnection network 20 and the information in /* h parameter of self-routing tag of the incoming cells. 
Another well known way is to use a self-routing multistage interconnection network where each node looks 
at the i* parameter of the routing tag to know the output line destination of the received cell and perform 
the corresponding switching. The size nxm of the input interconnection network 20 is used, where n is the 
number of input lines and m is the number of memory modules employed in the preferred embodiment of 
the switching apparatus according to the present invention. 

MEMORY MODULES 

A plurality of memory modules are employed in the switching apparatus. Memory modules are placed in 
between the input interconnection network 20 and output interconnection network 60 as shown in the 
preferred embodiment of the switching apparatus, FIG.2, according to the present invention. Each output 
line of input interconnection network 20 and input line of the output interconnection network 60 are 
connected to a single memory module. The memory modules employed in the disclosed switching 
apparatus of the present invention can be either single-port or double-port memory modules. In case of the 
use of dual port memory modules, the data-in port of a memory module is connected to a output line of the 
input interconnection network 20, while the data-out port of a memory module is connected to a input line 
of the output interconnection network 60, 

ATM-CELL WRITE OPERATION 
The FIG. 7 provide the detailed structure of the memory control component known as the slidtng-window 
memory controller 50„ 50,,^. 50,,. Every memory module 40„ 40 2t 40. has a corresponding sliding- 
window memory controller 50 H 50 2? .... 50,,, which is used to provide the write and read addresses for 
memory-write and memory-read operations needed for switching of ATM cells. The write operation 
performed by the memory controllers is shown by a flow diagram in FIG .8. According to the disclosed 
switching method of the present invention, the routing tag of the received ATM cells are sent to the 
controllers 50„ 50 2 , .... 50 m by the input modules 30„ 30 2 , .... 30 m and is shown in step 850 of FIG.8. As 
shown in step 852 of FIG. 8, the memory controllers 50„ 50 2 , .... 50,,, use value of the j parameter in the 
self-routing tag as the WRITE address to write the received ATM cell to the j* ATM location in the 
respective memory modules 40„ 40 2 , .... 40 m . The sliding-window memory controllers also use an array 
called output scan array (OSA) 54 n 54 2 , .... 54„ FIG. 7 each with a slots. As shown in step 854 of FIG. 8, 
the OSAs 54„ 54 2 , .... 54 m stores the scan plane value A, obtained from the self-routing tag (ij,k) of the 
received cells, in they th location of the OSA for every ATM cells that are written in the y* location of the 
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corresponding memory modules 40„ 40„ .... 40 o . The scan value of 0 in a given OSA sloty means that 
the memory location; in the corresponding memory module, is empty and does not hold a valid ATM cell. 

The valid ATM cell locations in the memory modules 40„ 40, 40 m always have a non zero scan value 

stored in the corresponding location of OSAs 54„ S4 t , .... S4 m . 

ATM-CELL READ OPERATION 
The ATM cell read operation performed by the memory controllers 50„ 50 2 , .... 50 m is shown by a flow 

chart steps 800 - 806 in FIG.8. The memory controllers SO,, 50, 50., also use a sliding-window counter 

in the read processor 56„ 56„ .... 56 m FIG. 7 respectively which keeps the current location of the sliding- 
window in the global buffer space using the variables SfV.sp and SfV.osv. The sliding-window counters 

56 " 561 56 ™ also u P datc the variables SfV.sp and SfV.osv every switch cycle using the traversal method 

(which actually is the variable update process) of the sliding-window as depicted by the flow chart in Fig 4. 
The sliding-window counters in 56„ 56„ .... 56„ FIG. 7 provide READ addresses for the output of the 
ATM cells from memory modules 40„ 40 t , .... 40 m in a given switch cycle. Every ATM-cell READ 
cycle, the valid ATM cells belonging to location SfV.osv from all the parallel memory modules 40„ 40„ .... 
40. are output. The validity of the cells is decided by the scan value k stored in the SfV.osv location of the 
OSA as follows, (i) according to step 802 of FIG. 8, if the content (which is the scan plane value) of the> 
location SfV.osv in OSA = 0 then it means that the location SfV.osv in a given memory module is empty 
and no read operation is performed, (ii) according to step 804, if content of location SfV.osv in OSA is not 
equal to SWsp then the cell is not valid and a stored cell is not read from the location SfV.osv . In such a 
case the cell is rather retained in the memory module for its turn in future read operations. (Hi) according 
to step 804 in FIG. 8, a cell is read out of the memory module only if the content location SfV.osv in OSA 
holds a value = SfV.sp i.e. the scan plane value in the counter 56i. Only under such a condition, step 806 of 
FIG.8, the memory controller provide the READ address SfV.osv for outputting the stored ATM cell from 
its memory module. As shown in step 806 of FIG. 8, every time a cell is output from a location j of a 
memory module, the memory controller updates the OSA by resetting OSA(j) =0 to denote the presence of 
an empty location in its memory module. 



SIMULTANEOUS WRITE AND READ OPERATIONS 

The disclosed switching apparatus can employ both single port or dual port memory modules. Use of dual 
port memory modules enhances the effective memory speed for read and write of ATM cells, and overall 
switching speed of the disclosed switching apparatus. Use of dual port memory will allow simultaneous 
WRITE and READ of ATM cells to and from a memory module in the same switch cycle only if WRITE 
and READ operations do not access same memory location. According to the disclosed switching method 
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of the present invention, the parameter assignment phase ensures that WRITE and READ of ATM cells do 
not access same memory location of a given memory module. Hence the disclosed switching method 
makes it possible to use the dual port memory modules for the switching apparatus of the present 
invention. The WRITE and READ operations (FIG. 8) performed by the memory controllers, can be used 
for both the single port and dual port memory modules. In case of the use of dual port memory modules, 
the memory controllers will need to produce write address as well as the read address for their memory 
modules in the same cycle. The order of WRITE and READ operations performed by the memory 
controllers (FIG 8) in a given cycle, to produce write and read addresses, does not matter as the operations 
performed in either order produce the same final result. For the sake of presentation, it can be assumed that 
in a given cycle, the memory controllers perform READ operations (FIG. 8) to produce read address 
before performing WRITE operations (FIG. 8) to obtain the write address. 

OUTPUT INTERCONNECTION NETWORK 

The output interconnection network 60 examines the destination information *<f in the header of the 
received ATM ceils. The output interconnection network provide switching of ATM cells received from 
the memory modules to the destined output lines of the switching apparatus. The output interconnection 
network architecture 60 can be similar to the one used for the input interconnection network 20. The self- 
routing multistage interconnection network, which are known in the art, can also be used for the output 
interconnection network to perform the needed input and output mapping of cells for switching purposes. 
Each node of the multistage interconnection network examines the destination information in the header of 
the received cell and perform respective switching functions. The size m x r of the output interconnection 
network 60 is used, where m is the number of memory modules and r is the number of output lines 
employed in the preferred embodiment of the switching apparatus according to the present invention. 

For those skilled in the art, it will be obvious that the disclosed switching apparatus and method according 
to the present invention can manifest in various embodiments depending on the kind of interconnection 
networks used for input interconnection network 20 and output interconnection network 60. Such 
modifications are to be considered under scope the disclosed invention. 

REQUIREMENT ON THE NUMBER OF MEMORY MODULES 

The minimum number of memory modules employed in the system or the number of memory slots 
employed in an output slot vector (OSV) depends on the memory sharing scheme used for the global buffer 
space of the disclosed switching apparatus. A best possible delay-throughput performance in shared global 
memory space can be achieved if a cell of an output queue is delayed only by the preceding cells of its own 
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non-empty queue. The disclosed switching method according to this invention achieves best possible 
delay-throughput performance by assigning routing parameters (ij.k) in such a way that consecutive output 
slot vectors are assigned to the consecutive ATM cells of an output queue. However, the successful 
assignment of a memory slot in an assigned output slot vector require that a sufficient number of memory 
slots are deployed in the OSVs. Alternatively, it requires that a sufficient number of memory modules be 
employed in the switching apparatus in order to achieve best possible delay throughput performance. 

The total number of memory location states available in the multidimensional global buffer space = p.m.a 
(FIG.3 ). Since the finite global buffer space is divided into various scan planes, the occupancy of the scan 
planes is made mutually disjoint i.e. if a memory slot (ij) is occupied on a given scan plane then the 
memory slot (/</) will be forbidden on all other scan planes. Thus, in effect, occupancy of y cells on any 
scan plane means p. y states will become forbidden. Therefore, if y incoming cells are assigned memory 
locations in the global buffer space then the remaining states available for occupancy is given by a (y ) 
where, 



a (y ) = Number of available states = (p.m. a- p. y)= p. (m. a- y) 



(D 



The multidimensional global memory space is shared by the cells belonging to all the output ports of the 
disclosed switching apparatus. One disadvantage of sharing is that because of its finite buffer space, it is 
possible for a single or a group of bursty source to occupy the entire buffer space and hence throttling the 
passage of ATM cells through the shared buffer for other source-destination pairs. Such a situation is a 
commonplace in a bursty environment and it causes the performance of a switch using a shared space to 
degrade especially at higher loads. In order to prevent such a situation, additional precautions are taken. 
One way to prevent such a situation is to impose an upper limit on the maximum length of output queues. 
An output port whose output queue has achieved the maximum queue length is considered saturated and 
an ATM cell arriving to a saturated output port is dropped in order to prevent an output queue from 
growing unboundedly. In the disclosed switching method, the length of an output queue is controlled by 
allowing the queue length not to exceed a certain predetermined number of scan-planes (p ). Thus the use 
of scan planes in multidimensional global buffer space of the disclosed switching apparatus, in effect, 
controls the queue length of an output port. 

Let the maximum length of an output queue allowed to be p.crfor a NxN size switch of the disclosed 
invention, employing a common global buffer space of capacity N.<r, where 1 £ p £ N and <rbeing the 
employed scan length. Let / be the minimum number of destinations whose cells can occupy the entire 
buffer space by growing to their maximum length. Assuming, that all the / output queues can grow to its 
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maximum length (= p. a), the number of cells occupying the entire shared buffer space = i.p.a . Under 
the conditions of complete occupancy of the global buffer space, the number of available states = 0. 
Hence, using eq. (I), the number of available states after an occupancy of ipa is given by 

a {ipa) =p {No- ipa) - 0 
Thus, the minimum number of destinations (/) having their cells or packets occupy the common global 

~n~ 

buffer space of capacity N.a = i - P * ^ 2 ) 

As mentioned earlier, it's possible for a group of destination packets to completely occupy the shared space 
of the ATM switch and not allow other source-destination connections to be established through the shared 
buffer switch. Such a phenomena would result in degradation of the best possible delay-throughput 
performance and excessive cell-loss especially at higher loads or under nonuniform or unbalanced traffic. 
A fair sharing scheme would be to always allow each of the destination packets a connection through the 
shared buffer space despite the fact that a subset of destination packets might occupy the entire shared 
buffer space. If we allow the buffer space of capacity N.a to be shared among N destination packets then 
additional memory-slots shall be employed in an OSV to always achieve best possible delay-throughput 
performance. 

Let the common buffer space capacity = N.a for a NxN switching apparatus employing a output slot 
vectors and p scan planes in its multidimensional global buffer space. In the case of complete occupancy 
of the buffer-space, the number of occupied states in an OSV = {N.a/ a)=N. 

Also from eq. (2), the minimum number of destinations that can completely occupy the shared space 





According to this, it is possible for the sliding-window to encounter an OSV in a given cycle, whose slots 
might already be full with the packets of / destinations, and furthermore, it is also possible for cells or 
packets destined to the remaining (AW ) output ports to be input to the current OSV in the same cycle. In 
order to avoid any additional delays, {N-i ) packets must be assigned the same OSV. In the worst case, 
this would require an OSV to accommodate additional (N-i ) cells or packets. Hence in order to achieve 
best possible delay throughput performance, the minimum number of memory-slots in an OSV of the 
global buffer space and the minimum number of memory modules to be deployed in the disclosed 
switching apparatus of FIG.2 
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= N+ (N-i) = 2N-* P . (3) 

[-1 

where, i ; = P from eq. (2). 

Its known in the art that buffer sharing schemes have varying impact on the performance of a switch 
(using a finite globally shared buffer space) under various traffic conditions and a switching apparatus 
using a common buffer space must provide for various buffer sharing schemes to manage for the 
contention among various ports for the finite global buffer space. The disclosed switching apparatus and 
the method according to the present invention allow for multiple sharing schemes to be implemented, such 
as complete sharing, complete partitioning and partial sharing of the finite global buffer space, by 
controlling the number of employed scan-planes (p) employed in the global buffer space. In order to 
achieve best possible delay-throughput performance for a given switch size (N x N ) and for a given buffer 
space (N.a ): depending on the sharing scheme used, different requirement is placed on the minimum 
number of memory modules to be employed in the disclosed switching apparatus. Here, a is the scan- 
length or the number of OSV, and p is the number of the scan-planes (p) employed in the system. 

COMPLETE SHARING OF A FINITE BUFFER SPACE 
According to one embodiment of the present invention, the NxN ATM switching apparatus using 
multidimensional global buffer space may employ complete sharing of memory space of N.a where a is 
the number of output slot vectors (OSV) employed in the system. In the case of complete sharing of a 
finite buffer space with no restriction on the output queue length, it will be possible for a single-destination 
cells or packets to occupy the permitted shared space of N.<j. That is, it would be possible for an output 
queue to grow up to a length ofM<r. In this case, the number of scan-planes employed = p = N ; the 

~N~ 

minimum number of destinations having their packets in the shared space = / = P =\ (eq. 2); In order 
to achieve best possible delay-throughput performance, the total number of slots required in an OSV must 

\i\ 

at least be - 2N - -2N - \ (eq.3) ; hence, the minimum number of memory modules employed in 

the switching apparatus of the present embodiment allowing complete sharing = 2N - 1. 

COMPLETE PARTITIONING OF A FINITE BUFFER SPACE 
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In another embodiment of the present invention, the switching apparatus of a size NxN may use complete 
partitioning of its finite global buffer space N. a equally among its N destinations, where a is the number 
of output slot vectors employed in the system. In the case of complete partitioning of a finite buffer space 
among its destinations, the shared buffer space of capacity N.o is divided into N partitions, i.e. an output 
queue is not allowed to exceed a length of a i.e. one scan-length. Hence, the number of scan-planes 
employed The minimum number of destinations having their packets in the shared space = / = 



P -N (eq.2). In order to achieve best possible delay-throughput performance, the minimum number 

[-1 

of slots required in an OSV must be = 2N - P = N (eq.3) . According to the present embodiment, the 
disclosed switching apparatus simply reduces into the case of dedicated output buffer switch where a 
constant amount of dedicated buffer is employed at each output port and no sharing is allowed. 

PARTIAL SHARING OF A FINITE BUFFER SPACE 
According to yet another embodiment of the present invention, the switching apparatus may employ partial 
sharing of its finite global buffer space. Unlike the case of complete sharing approach, no one single 
destination queue is allowed to grow to a length so as to occupy the shared buffer space of N.a , while 
unlike the case of complete partitioning approach, an output queue is allowed to grow beyond one scan- 
length (i.e. cr). According to the present embodiment of the switching apparatus, a restriction is imposed 
on the maximum length of an output queue. A maximum length of an output queue can take a value 
anywhere between a and N.a. Thus, according to this scheme, the number of scan-planes employed in 
the system = k f where 1 < k < N . The minimum number of destinations having their packets in the 

shared space - / = * (eq.2). In order to achieve best possible delay-throughput performance, the 

f-i 

minimum number of slots required in an OSV « IN - k 1 (eq.3). Hence according to the present 
embodiment of the switching apparatus allowing a partial sharing of finite global buffer space, the 

r-i 

minimum number of memory modules employed in the system -IN- & . 
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TABLE 1: Requirement on the minimum number of memory modules for different buffer sharing schemes 
for various embodiments of the disclosed switching apparatus of Size NxN and memory space of N.a 
(note: If a is the scan length then N memory modules will be constitue a memory space of N.o) 



Buffer Sharinp ^rh*»m*» 

(for a shared space= 
N.a) 


Required minimum 
number of memory 
modules in the system 
for best delay 
throughput performance 


Required minimum 
number of extra 
memory modules for 
best delay throughput 
performance 


Number of scan-planes 
employed in the system 


Complete Sharing 


2N-1 


N-1 


N 


Complete Partitioning 


N 


0 


1 


Partial Sharing 


1-1 

2N- 1 * 1 


i-i 

N- 1 * 1 


k 

(1 <k<N) 



DECENTRALIZED PIPELINE OPERATION OF THE DISCLOSED ATM SWITCHING APPARATUS 

According to another preferred embodiment of the switching apparatus of the present invention, the overall 
switching function of the switching apparatus is partitioned into multiple stages such that all of them can 
perform needed switching functions independently in the same cycle without any conflict. Once the 
switching apparatus is divided into independent stages then these stages can operate in a pipeline fashion 
on received ATM cells or packets to achieve overall switching operation. The switching operation is 
decentralized in the sense that there is no central controller directly coordinating, controlling or managing 
the operations of multiple stages of the disclosed switching apparatus. 

FIGS. 9 illustrates a method to partition the overall switching function according to another embodiment 
of the disclosed switching apparatus and method. According to the present embodiment, the overall 
switching function of the apparatus is divided in to multiple and independent stages as following : (i) first 
stage, also called self-routing parameter assignment stage, consists of the header processing circuits and the 
self-routing parameter assignment circuit 14, (ii) second stage consists of the input interconnection network 
20 and its operations performed on the received ATM cells, (iii) third stage operation include the 
operations involved with the WRITE of received cells to the memory modules , (iv) fourth stage include 
the operations performed for the READ of ATM cells from the memory modules, and (v) fifth stage 
include output interconnection network 60 and associated operations performed on the received cells. In 
this example, the switching apparatus is divided into 5 pipeline stages. However, it should be understood 
by those skilled in the art that there may exist other embodiment of the present invention according to 
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which the switching apparatus can be divided into more than 5 or less than 5 pipeline stages and such 
modifications shall be considered within the scope of the present invention. According to the pipeline 
operation of the switching apparatus of the present invention, the pipeline stage that takes the longest time 
to complete its switching function is chosen to be the pipeline cycle time (t). The pipeline cycle time is 
always chosen such that the longest pipeline stage is much less than the switching time (T) of the non- 
pipeline based switching apparatus. In Fig. 5, the pipeline cycle t is shown, as an example, to be one fiah 
of the switching cycle i.e. T = St. FIG. 9 shows the time chart for scheduling various switching operations 
in different stages at different pipeline cycles. Various stages of the time chart is denoted by (s.t) where s 
denote the pipeline stage and t denote the pipeline cycle. For example, in the first pipeline cycle, an 
incoming cell goes through the first stage of the switching apparatus where a self-routing tag is computed 
and assigned to the cell. First stage operations in the first pipeline cycle is denoted by the process state 
(1,1). After obtaining their routing tags in the first stage, the group of incoming cells in the first pipeline 
cycle, are sent to the second pipeline stage in the second pipeline cycle, denoted by process (2,2) in the 
time chart, for their switching to respective memory modules by the input interconnection network. In the 
second pipeline cycle, a new set of incoming cells are also sent to the first stage for obtaining their self- 
routing tag which is indicated by the process state (1,2). The process (2,2) and process (1,2) are executed 
in parallel and as the pipeline stages fill up with multiple tasks, a great degree of parallelism and hence a 
speed up in throughput is achieved by the disclosed switching method and apparatus while performing the 
switching of ATM cells. 

While operating multiple stages in a pipeline fashion of a switching apparatus, it becomes quite important 
to have a way to update global variables in one stage and still have the updates available locally to another 
stage that needs it for its operation. This task is quite easy for the switching systems that use a centralized 
controller as any update in a global variable is coordinated and managed centrally and all the updates are 
readily accessable to all the components of the switching system that needs it. The solution to this problem 
is not obvious for a pipeline based switching apparatus of the present invention. For example, for the 
pipeline system described in FIG. 9, when a cell is read out of the memory in the fourth stage, the 
information regarding the availability of the memory location in the global buffer space must be made 
avaiable, in some way, to the first stage where the new incoming cells are assigned self-routing 
parameters based on the current occupancy of the global buffer space. In order to achieve a coordinated 
operation of the present embodiment of the pipeline based switching apparatus, some additional update 
operations might needed by some pipeline stages in order to accomodate for the centrally updated global 
variables. The switching functions along with the needed global variable update operations for the present 
embodiment of the disclosed switching apparatus are presented for each pipeline stages as follows. 
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PIPELINE STAGE - 1 : SELF-ROUTING PARAMETER (ij.k) ASSIGNMENT STAGE 

The parameter assignment stage consists of header processing circuits and parameter assignment circuit 14 
of the switching apparatus. As mentioned earlier in an exemplary embodiment of the parameter 
assignment circuit 14 FIG. 6, it uses two processors 600 and 650. Both of these processors use sliding- 
window counters which are updated according to the flow diagram of FIG.4. The parameter assignment 
circuit also uses other counters such as QLC 620 , LCC 630 and a scan table 660 in order to assign self- 
routing parameters to incoming cells. However, in order to correctly assign parameters to incoming cells, 
these counters need to be updated each cycle for dynamically changing global variables, for example, to 
account for outgoing cells and newly emptied memory locations due to the read operation performed in 
pipeline stage 4 of the switching apparatus. For each outgoing cells in pipeline stage-4, the pipeline stage 
1 needs to update the corresponding queue length counter (as it will be reduced by one for an outgoing 
cell) and the scan table 660 (as it needs to update the availability of memory locations in the global 
memory space for outgoing cells in the pipeline stage 4 ). 

The disclosed switching apparatus and the method is configured to achieve best possible delay-throughput 
performance and employs the required minimum number of memory modules to this effect. The disclosed 
switching apparatus and method assigns the self-routing parameters (FIG. 5) to incoming cells in such a 
way so as to achieve best possible delay-throughput performance. The disclosed switching method 
guarantees that one cell is read out of global buffer space each pipeline cycle for each output line of the 
switching apparatus provided that a cell for a given output line is present inside the global buffer space. 
Accordingly, in the beginning of each pipeline cycle, stage- 1 updates its queue length counters i.e. QLC or 
Q d 620 by decrementing non-zero queue lengths by one to account for the cells being read out of the 
global memory space for respective output lines in the previous pipeline cycle of stage 4 . Similarly, the 
processor 2 updates its scan table in the beginning of each pipeline cycle to take into account for the 
change in the occupancy of the global buffer space due to the read operation performed in the previous 
pipeline cycle by the pipeline stage 4. In order to update its scan table, the processor 2 makes use of the 
fact that in stage 4, each cycle the cells pointed by SfV.osv and belonging to the scan-plane SW.sp are 
output (step 806, FIG. 8). The processor 2 uses this fact and hence uses the previous value of the sliding- 
window SW(osv.sp) to update its scan table in the beginning of each pipeline cycle. In this process, it 
assumes that all the cells belonging to the slots in column SfV.osv of its scan table are output if the content 
of the slot is equal to StV.sp. To take into account for the output cells, the processed resets all such 
locations in its scan table, to zero, to indicate the availability of the memory locations in the global buffer 
space. 

Each cycle the processor 1 performs operations in the following sequence: 
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(i) Update QLC (step 408 FIG. 4) to account for outgoing cells in the previous cycle as follows 

For d = I to r ; // For each output lines 
if Q d >0thenQ d =Q d -l; 

(ii) Update sliding window counter i.e. SW.osv and SW.sp to the next value according to steps 410-414 of 
the flow chart in FIG. 4. 

(iii) Now proceed with the switching functions (step 404 of FIG.4) for processorl which is the 
determination of parameters (J and *) as shown in steps 502- 524 of flow diagram in FIG.5 for the 
incoming cells in that given cycle. 

In the present embodiment of the switching apparatus where its overall switching function has been 
partitioned into multiple stages and are made independent of each other so as to achieve a pipeline based 
switching operation : the pipeline stages that use sliding-window counter, update its value with reference 
to the pipeline cycle as opposed to the switch cycle (in steps 400-414 of FIG. 4.). 

Each cycle, processor 2 perform operation in the following sequence: 

(i) Update (step 408 of FIG. 4) scan table 660 with previous value of the sliding-window counter 670 to 
take into account for the outgoing cells in the previous cycle. According to the disclosed switching 
method, each cycle, the cells belonging to the output slot vector SW.osv having its scan value k equal to 
SW.sp are output. This switching method is used to update the scan table as follows. 

For / - 1 to m\ li For slots in the previous output slot vector 
if ST(i 9 SW.osv) = SW.sp then setST(/ v 5ff p .asv)«0. 

(it) Update sliding window counter i.e. SW.osv and SW.sp to the next value according to steps 410-414 of 
the flow diagram in FIG. 4. 

(iii) Now proceed with the switching functions (step 404 of Fig. 4) for this processor i.e. the assignment of 
parameter / for the incoming cells for the previously assigned values of output slot vector j and scan-plane 
*. In this process an available ^ memory slot in they* column of the scan table is assigned as the P 
parameter and the scan plane value, k is stored in the corresponding scan table slot i.e. ST(v) = k\ Also 
while assigning << h parameter, attempt is made to assign different f* value to the cells belonging to the same 
cycle. This process helps to enhance the parallelism in the input and output mapping function performed 
by the input interconnection network 20 of the stage 2 while routing the received cells or packets to 
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different memory modules. One of the methods of assigning /* parameter using the scan table, for the 
known value of / and k is shown by the following pseudo code. 

Each cycle, initialize / [\..m] =0; // this keeps track of assigned memory modules in a cycle 
For each incoming cells of a cycle with parameters j and * ; 
For / = 1 to m \ 

if ( ST(iJ) = 0 and t[/] = 0 ) then 

{ set ST(iJ) = assign / for cells routing tag; 
= 1 ; exit } 

It can be noted from the pseudo code above that while assigning the /* parameter, processor 2 makes an 
attempt to assign different value of / i.e. different memory modules to the cells belonging to the same 
cycle. 

Another way to assign the ,< h parameter, is to assign different values oft (i.e. different memory modules) to 
the cells belonging to the same cycle but in an increasing order. As an example, if / =3 has been assigned 
to a cell of the cycle then for the next incoming cell, attempt is made to assign / > 3, if none of the greater 
values of i are available then only the smaller values are chosen. 

Once the assignments of self-routing parameter (ij,k) are completed in the first stage, the incoming cells 
are attached with their self-routing tags and are sent to the second pipeline stage in the following pipeline 
cycle. 

PIPELINE STAGE -2 : CELL ROUTING WITH INPUT INTERCONNECTION NETWORK 

In a given cycle, the input interconnection network receive cells who have been assigned self-routing tag 
0J,k) in stage- 1 in the previous pipeline cycle. Input interconnection network uses the r* parameter of the 
received cells and perform routing of the cells to the memory modules denoted by their <* parameter. 

PIPELINE STAGE -3 : ATM-CELL WRITE OPERATION 

In order to achieve write and read of ATM cells in the same cycle, dual port memory modules are 
employed in the switching apparatus of the present invention. The use of dual port memory module for the 
disclosed switching apparatus and method has been discussed in an earlier section. The parameter 
assignment method of the disclosed invention, ensures that the write and read of ATM cells never access 
the same memory locations at the same time. Accordingly, the write of ATM cells are made independent 
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of the read of ATM ceils. During the write stage, the local memory controllers receive the routing tag 
information from the received cells and generate respective addresses for the received cells to be written in 
the respective memory modules. The controllers use the flow diagram of FIG. 8 to perform their write 
operation. 

PIPELINE STAGE -4: ATM-CELL READ OPERATION 

The pipeline stage 4 perform the read of ATM cells from the memory modules employed in the disclosed 
switching apparatus. The pipeline stage 4 also called the READ stage basically consists of the local 
memory controllers performing the read operation according to the flow diagram of FIG. 8. The memory 
controllers use a sliding-window counter which is initialized to SW.osv « I and SW.sp =1 in pipeline cycle 
4. Because of the pipeline operation of the switching apparatus, the cells that have entered the stage 1 with 
the initial value of the sliding-window counter become available to stage 4 for READ operation only in the 
pipeline cycle 4. Therefore, while following the sliding-window update process shown by flow diagram in 
FIG. 4, the cycle (which is pipeline cycle) in steps 400*414 is offset by 4 for sliding-window counter of 
the READ stage. According to this, in the fourth pipeline cycle, the sliding-window window of the READ 
stage will indicate "cycle = 0" (the step 400 of flow diagram in FIG. 4) and the sliding window counters 
will be initialized to SW.osv = 1 and SW.sp =1 and only then the first read operation takes place. Only after 
the first read of ATM cells from the memory modules i.e. after the pipeline cycle 4, the sliding-window 
counter of the read stage is updated in the beginning of each subsequent cycles. The subsequent read 
operation is performed by the local controller based on the new value of the sliding-window counter. 

PIPELINE STAGE -5 : CELL ROUTING WITH OUTPUT INTERCONNECTION NETWORK 

The pipeline stage 5 mainly consists of the output interconnection network 60 . Each memory module's 
data-out port is connected to an input line of the output interconnection network. In a given pipeline cycle, 
the output interconnection network receives cells output by stage 4 in the previous pipeline cycle. The 
output interconnection network obtains the final destination address K d' of each received cell and perform 
routing of cells to respective output line destinations. All the switching decisions are made locally by the 
output interconnection network based on i.e. destination information in the header of the received cells. 

EXAMPLE OF THE PIPELINE OPERATION OF THE SWITCH 
FIG. 10 shows an example of a configuration of a 4x4 ATM switching apparatus according to the disclosed 
invention. The switching apparatus, in this example, employes memory modules each having a capacity to 
store 12 ATM cells. The switching apparatus, in this example, is configured to handle a maximum queue 
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length of 24 ATM cells within the global buffer space for any given output port. This means that two scan 
planes (p =2) would need to employed in the multidimensional buffer space of the switching apparatus of 
the disclosed invention. Based on these values, i.e. N = 4 and p = 2, the required minimum number of 
memory modules is calculated, using eq. (3), to be 6 i.e. m = 6. Also shown in the FIG. 10 is an stream of 
incoming cells input to the example switching apparatus for 8 pipeline cycles. In FIG. 10, input ports of 
the 4x4 switch are denoted by W,X,Y and Z respectively. Also, the group of cells arriving in eight input 
cycles are denoted by letter 'A' through *H'. Each incoming cell is denoted by its output line destination 
address. For example, the cell arriving in second pipeline cycle on the input port X is destined to the 
output line '2'. Similarly, the group of cells arriving in second pipeline cycle is denoted by «B\ 

FIG. 11 also shows different pipeline stages of the switching apparatus according to the present invention. 
Since the switching apparatus is 4x4 and uses 6 memory modules, a 4x6 self-routing and a non-blocking 
interconnection network is used for pipeline stage 2 . Similarly, a 6x4 self-routing and a non-blocking 
interconnection network is used for pipeline stage 5 in the exemplary embodiment of the disclosed 
switching system according to this invention. Each memory modules are implemented as dual port 
memory and use the local memory controller for WRITE and READ operations. 

FIG. 12 shows the time chart for the pipeline operation of the exemplary 4x4 switching apparatus of FIG. 
11 for 12 pipeline cycles. The incoming streams of ATM cells which are input for 8 pipeline cycles, as 
shown in FIG. 10, are used to demonstrate the detailed pipeline operation of the 4x4 switching apparatus 
according to the disclosed invention. For explanation purposes, A( 1,1) in the time chart, denotes stage 1 
of cycle 1 and it indicates that the input cells belonging to input group 'A' are being processed by the 
assignment stage of the switching apparatus of FIG. 11. Similarly, A(2,2) indicate that the group 'A' 
input cells are in the second pipeline stage in the second pipeline cycle, that is group 'A' input cells are 
being switched by the input interconnection network 20. A(3,3) indicate that the group 'A' input cells are 
being written to respective/ location of the /* memory modules in stage 3 of the pipeline cycle 3 which 
uses the flow diagram for WRITE operation in FIG. 8. R(4,4) means that the stage 4 is performing its read 
operation, according to the flow diagram in FIG. 8, in pipeline cycle 4. 0(5,5) means that in stage 5, and 
pipeline cycle 5, cells that were read out of the memory modules in the previous pipeline cycle, are being 
switched to their final output line destination '<f by the output interconnection network. Because of the 
pipeline operation performed on the incoming cells by different stages, the output of cells begin in the fifth 
pipeline cycle. FIG. 12 shows that after the initial delay of 5 pipeline cycles, cells are output (if present in 
the buffer) every pipeline cycle thereafter. FIG. 12 shows the operation of different stages of the disclosed 
switching apparatus on the incoming cells starting from A(l,l) when the first group of cells are input to the 
switching apparatus in the first stage in the first pipeline cycle, and ending at 0(5,12) when a group of 
ATM cells are output by the 5* pipeline stage of the 12* pipeline cycle. 
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FIG. 13 shows the actual operation of the parameter assignment stage for the first group of incoming cells 
in the first pipeline cycle. 

FIGS. 14-1 and 14-2 show the pipeline operations performed in the second pipeline cycle by the first two 
stages of the 4x4 example switching apparatus of the present invention. 

FIGS. 15-1, 15-2, 15-3 show the pipeline operations performed by first three stages of the switching 
apparatus in the third pipeline cycle. 

FIGS. 16-1, 16-2, 16-3, 16-4, 16-5 show the respective pipeline operations performed in the fourth pipeline 
cycle by different stages of the switching apparatus. 

FIGS. 17-1 to 17-5 show the respective pipeline operations performed by different pipeline stages in the 5 th 
pipeline cycle. 

FIGS. 18-1 to 18-5 show the respective switching operations performed by different pipeline stages in the 
6 th pipeline cycle. 

FIGS. 19-1 to 19-5 show switching operations performed by different pipeline stages in the 7 th pipeline 
cycle. 

FIGS. 20-1 to FIGS, 20-5 show switching operations performed by different pipeline stages in the 8 th 
pipeline cycle. 

FIGS. 21-1 to 21-4 show switching operations performed by different pipeline stages on the received cells 
in 9th pipeline cycle. , 

FIGS. 22-1 to 22-3 show switching operations performed by different stages in the 10 th pipeline cycle. 
Note that in the 10 th pipeline cycle, only three stages are active ( in the sense that changes are taking place) 
and have received new cells to process, while the first two stages are idle and they do not have any new 
cells to work on. 

FIGS 23-1 and 23-2 show switching operations performed by only last two stages in the 1 1* pipeline cycle 
i.e. the READ stage and the output interconnection network stage. It can be noted that eventhough there 
are no new cells to be processed by the first stage, the switch still needs to process previously input cells in 
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its memory space. Hence in the following cycles the last two stages will be active outputting the cells 
resident in the memory space. 

FIG. 24 only shows the last stage of the switch in the 12'" pipeline cycle which outputs the cells read in 
stage 4 (shown in FIG. 23-1) in the previous pipeline cycle i.e. 1 1* pipeline cycle. The READ stage is also 
active in the 12th pipeline cycle, however it is not shown. 

The detailed time chart for input and output of the same stream of cell arrivals (shown in FIG. 10) is given 
in FIG. 25. FIG. 25 also shows switching operations in different pipeline stages at different pipeline cycles 
along with the sliding-window counter update process for the READ stage. It can be noted that for READ 
stage the sliding-window counter update process starts only after read of cells in the fourth cycle and 
thereafter, the READ stage sliding-window counter (which is resident in the memory controllers) continues 
to update itself for all the consecutive pipeline cycles. 

FIG. 26a shows a stream of incoming cells input to the switching apparatus for 12 consecutive cycles. 
FIG. 26b shows the occupancy of the multidimensional global buffer space after WRITE operation 
performed by the switching apparatus in the pipeline cycle 14 and before the READ operation performed 
in the pipeline cycle 15. The sliding-window counter in the 15- pipeline cycle in the read pipeline-stage 
show that it is currently processing the cells belonging to the SW.osv = 12 and SW.sp =1. The circled 
packets indicate the earlier occupancy of the cells in the global buffer space before being output in earlier 
cycles. 

FIG. 27 shows the time chart for the input and output of ATM cell streams of FIG. 26a and the 
corresponding update of the sliding-window counter in the 4* pipeline stage where the read operation is 
performed to output ATM cells from parallel memory modules of the disclosed switching apparatus. 

FIG. 28a shows a stream of ATM cells input for 16 consecutive pipeline cycles to the example 4x4 ATM 
switching apparatus according to the present invention. The cell airivals in the last several cycles are all 
destined to the output 4 and constitute an unbalanced traffic. For such a traffic, it is important to control the 
queue buildup inside the common memory space. In the lack of any control, the entire memory space can 
be occupied by cells of a given output port and thus prevent establishment of any other connection for any 
other pair of input and output ports through the common memory space. In the example switch of FIG. 11, 
growth of a queue inside the common memory space is controlled by the parameter assignment circuit. 
Once the queue length exceeds a threshold value, all other incoming cells, destined to the congested output 
port, are dropped. This allows for other input ports to establish connections through the global buffer 
space to non-congested output ports. 
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FIG. 28b shows an occupancy of the multidimensional buffer space after the WRITE operation is 
performed in the 18 th pipeline cycle by the 3 rd pipeline stage of the 4x4 switching apparatus of FIG. II, 
according to the present invention. It is shown that the last three cells input in the 16 th pipeline cycle were 
dropped as the length of the output queue destined to output port 4 reached its upper limit i.e. 24 ATM 
cells in the multidimensional global buffer space. FIG. 28b also presents a senario of queue build up for a 
congested output port inside the multidimensional global buffer space with head-of-line (HOL) cell being 
resident in the output slot vector (OSV) on the scan plane (sp) as pointed by the sliding-window counter of 
the READ stage. The queue of cells destined to the output port 4 is shown by a dotted line and is marked 
as 4 abcdef . The first segment of queue 'ab' is resident on the second scan plane which holds the current 
traversal of the sliding-window. Consecutive arrival of cells destined to the output port 4 causes the cells 
to occupy slots in consecutive output slot vectors on the next scan plane and a queue 'cd' is formed on the 
first scan plane. Further arrival of cells destined to the output port 4 causes the cells to occupy available 
slots in consecutive output slot vectors on the second scan plane. The queue grows only up to the length 
p. a- = 24 cells. Any further arrival of cells destined to output port 4 are dropped as the output queue has 
reached its maximum length allowed in the finite global buffer space. The last segment of the queue is 
denoted by 'ef where the last three incoming cells, destined to output port 4, were dropped. 

While the disclosed switching apparatus and the switching method has been particularly shown and 
described with reference to the preferred embodiments, it will be understood by those skilled in the art that 
various modifications in form and detail may be made therein without departing from the scope and spirit 
of the invention. Accordingly, modifications such as those suggested above in the document and some 
more suggested as follows, but not limited thereto, are to be considered within the scope of the present 
invention. For example: 

(i) In the exemplary embodiments described above, the disclosed switching apparatus and the switching 
method are illustrated for switching of ATM cells with multiple input ports and multiple output ports 
employing a plurality of memory modules and employing decentralized pipeline control. However, the 
same switching apparatus and switching method can be used with a little or no modification to switch fixed 
packets of another size (i.e. other than 53 bytes) or even to switch packets of variable lengths; 

(ii) In the preferred embodiments of the present invention, a means to achieve decentralized pipeline 
control for the overall switching function of the switching apparatus has been described above. However, 
it may be possible to control the disclosed switching apparatus by a centralized controller rather which may 
use the disclosed switching method with some modifications. 



32 



OCID: <WO 992638 1 A 1 _L=- 



WO 99/26381 PCT/US98/24299 



(iii) In the exemplary embodiments described above, a method for the assignment of self-routing 
parameters OJ.k) are described. It may be possible to build faster assignment circuit 14 which may modify 
the assignment process, as shown by flow diagrams and as described above in the respective sections, in 
order to achieve a faster assignment or computation of the routing parameters (ij,k). 

(iv) In the exemplary embodiments described above, input modules have been employed in the system to 
hold the received cells for a predetermined length of time. It may be possible to use the disclosed 
switching apparatus and employ more modules (similar to input modules) or buffers at various points of 
the apparatus to adjust for the speed or for synchronization of various pipeline stage operations. 

(v) In the preferred embodiments of the present invention, a means to achieve decentralized pipeline 
control for the overall switching function of the switching apparatus has been described where the overall 
switching function has been partitioned in 5 different stages for its pipeline operation. It may be possible 
to modify the partitioning of the switching function to have more than 5 different pipeline stages or less 
than 5 pipeline stages and accordingly modify the pipeline operation of the disclosed switching apparatus 
and the switching method. 

(vi) In the pipeline operation of the disclosed switching apparatus, dual-port memory modules have been 
used in the example. It is possible to use single port memory having twice or more the speed of dual port 
memory. 

(vii) The disclosed switching apparatus and method according to the present invention can manifest in 
various embodiments depending on the kind of interconnection networks used for input interconnection 
network 20 and output interconnection network 60. Such modifications are to be considered under scope 
the disclosed invention 

(viii) The disclosed switching apparatus, its is possible to modify the parameter assignment stage by 
partitioning the process in two separate stages, where the first stage determine the j and k routing 
parameters and the second stage determine the / parameter. 
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What is claimed is: 

1. An asynchronous transfer mode (ATM) cell switching apparatus for processing and switching of 
asynchronous transfer mode cells between a plurality of input lines and a plurality of outgoing lines* each 
cell having a data portion and a header portion, header portion of which carry a cell's destination as an 
outgoing line, the asynchronous transfer mode switching apparatus comprising: 

a plurality of memory modules in which incoming cells are stored and from which stored cells 
are read selectively by a corresponding local memory controller; 

a self-routing parameter assignment circuit which provide a self-routing tag for incoming cells 
to be used for various switching functions of the apparatus; 

an input interconnection network which uses the information in the said routing tag of received 
cells on input lines to connect the said input lines to one of the said memory modules; 

an output interconnection network which uses the destination information from the header 
portion of cells read from a plurality of memory modules to connect the said memory modules to one of 
the said destined output lines. 

a control means to achieve decentralized and pipeline operation of the overall switching 
apparatus. 



2. The asynchronous transfer mode cell switching apparatus of claim 1, further comprising: 

a header processing circuit, used for each said input lines, placed in between the said input lines 
and said input interconnection network, connecting input lines to input interconnection network and self- 
routing parameter assignment circuit, used to hold and process incoming ATM cells' headers for 
extraction of cells* output line destination address, deliver the incoming cells destination address to self- 
routing parameter assignment circuit, obtain a self-routing tag from the self-routing parameter assignment 
circuit, attach the self-routing tag to the said incoming cells, deliver cells with attached self-routing tag to 
said input interconnection network; 

a decentraiized-control means to alleviate the need for a collective control of multiple stages of 
the switching apparatus by a centralized controller; 

a pipeline-control means to provide the said multiple stages to operate in a pipeline fashion to 
speed up the overall switching performance of the switching apparatus. 



3. The asynchronous transfer mode cell switching apparatus of claim 1, 

wherein overall switching function is partitioned in multiple independent set of operations such 
that said independent set of operations, when executed in sequence, provide the overall switching 
function; 

wherein each independent set of operations form multiple independent stages of the switching 
/ apparatus; 

wherein the said independent stages perform their switching operations based on the information 
available locally to a given stage and based on the information available in the routing tags of the 
received cells; 
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wherein the said independent stages perform their switching operations on incoming cells in a 
pipeline fashion. 

4. The asynchronous transfer mode cell switching apparatus of claim 1, 

wherein a self-routing parameter assignment circuit which is placed before the input 
interconnection network, uses a method and the output line destination address in the headers of the 
incoming cells to provide self-routing tags for incoming cells to facilitate the switching operations in the 
switching apparatus; and 

wherein the self-routing tag is attached to the incoming cells for its processing and switching in 
the switching apparatus; and 

wherein the input interconnection network receives cells with attached self-routing tag and uses 
information in the attached self-routing tag of cells in order to deliver them to one of the said memory 
modules; and 

wherein the said memory modules use local memory controllers which are independent of other 
memory controllers used in the switching apparatus; and 

wherein the said memory controllers use a switching method and the information in the attached 
self-routing tag of the received cells to generate locally and independently of other memory controllers, 
the WRITE and READ addresses for the said memory modules; and 

wherein the said memory modules use the WRITE address generated by local memory 
controllers to store the received cell; and 

wherein the said memory modules use the READ address generated by the local memory 
controllers to selectively output a stored cell; and 

wherein the output interconnection network receives cells read from the memory modules and 
uses information in the attached self-routing tag of cells in order to deliver them to one of the said output 
lines. 



5. The switching apparatus of claim 1, 

wherein the number of memory modules used in the switching apparatus depends on the 
memory sharing scheme used for the global memory space among cells of different output lines; and 

wherein the number of memory modules used is equal to or greater than sum of the number of 
input and output lines less one, or the number of memory- modules is less than the sum of input and 
output lines less one, or the number of memory modules is equal to output lines, or the number of 
memory modules is equal to the number of input lines. 



6. The switching apparatus of claim 1, 

wherein the input information is received and processed as packets of fixed lengths, each packet 
having a data portion and a header portion, header portion of which cany a packet's destination as an 
outgoing line of the switching apparatus. 
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7. The switching apparatus of claim 1 

wherein the input information is received and processed as packets of variable lengths, each 
packet having a data portion and a header portion, header portion of which carry a packet's destination as 
an outgoing line of the switching apparatus. 

8. An asynchronous transfer mode cell switching apparatus comprising: 

a plurality of input lines and a plurality of output lines for receiving incoming and outgoing 
ATM cells having a data portion and a header portion, the header portion of which contains the 
destination address which is one of the output lines; 

a self-routing parameter assignment circuit to assign a self-routing tag to the incoming ATM 
cells for their processing through different stages of the switching apparatus; 

an input interconnection network to receive ATM cells with attached self-routing tag , and use 
the information in the tag of each cell on a plurality of incoming lines to connect them to a plurality of 
memory modules; 

a plurality of memory modules using corresponding memory controllers to get the WRITE and 
READ addresses to store the incoming cells to and retrieve the outgoing cells from; 

a plurality of said local memory controllers using a means to generate WRITE and READ 
addresses based on the information in the self-routing tag of the incoming cells; and 

a means for providing various memory sharing schemes for fair sharing of global memory space 
among the cells destined to a plurality of said outgoing lines; 

9. The asynchronous transfer mode cell switching apparatus of claim 8, further comprising: 

a means for local memory controllers to use information in the self-routing tag of received cells 
and manage the corresponding memory modules to provide a given memory-sharing scheme for global 
memory space including all the ATM cell locations in a plurality of memory modules; 

a means for controlling the length of ATM cell queues, destined to a plurality of outgoing lines, 
within the global memory space including all the ATM cell locations in a plurality memory modules; 

10. The asynchronous transfer mode switching apparatus of claim 8, 

wherein the number of memory modules used in the switching apparatus depends on the 
memory sharing scheme used to achieve fair sharing under different traffic conditions for the global 
memory space among cells of different output lines; 

wherein the number of memory modules used is equal to or greater than sum of the number of 
input and output lines less one, or the number of memory modules is less than the sum of input and 
output lines less one, or the number of memory modules is equal to output lines, or the number of 
memory modules is equal to the number of input lines 
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1 i . An asynchronous transfer mode ATM switching apparatus, comprising: 

a plurality of input lines and a plurality of outgoing lines for receiving incoming and outgoing 
ATM cells having a data portion and header portion, the header portion of which contains the destination 
address which is one of the outgoing lines 

a self-routing parameter assignment circuit to assign a self-routing tag to the incoming ATM 
cells for its traversal through the different stages of the switching apparatus; 

an input interconnection network to receive ATM cells with attached self-routing tag , and use 
the information in the tag of each cell on a plurality of incoming lines to connect them to a plurality of 
memory modules; 

a plurality of memory modules using local memory controllers to obtain the WRITE and READ 
addresses to store the incoming cells and retrieve the outgoing cells; 

a plurality of said local memory controllers using a means to generate WRITE and READ 
addresses based on the information in the self-routing tag of the incoming cells; 

a control means for providing switching apparatus and its switching functions to be divided in 
multiple independent stages to achieve pipeline operation of the overall switching apparatus; 

12. The ATM switching apparatus of claim 11, 

wherein the switching apparatus provide a means to alleviate the need for collective control of 
multiple stages of the switching apparatus by a centralized controller; 

wherein the said multiple stages operate in a pipeline fashion to speed up the overall switching 
performance of the switching apparatus; 

wherein one switching cycle of the switching apparatus include multiple pipeline cycles, the 
number of pipeline cycles being a function of the number of pipeline stages employed in the switching 
apparatus; 

wherein the said multiple pipeline stages perform needed switching functions based on the 
information contained in the self-routing tags attached to the received ceils and local variables belonging 
to a given pipeline stage. 



13. A method of switching, called the Sliding- Window switching scheme, for an ATM switching 
apparatus, the method comprising the steps of: 

depicting the entire memory locations for cells in all the memory modules in the switching 
apparatus as a multidimensional global memory space to be used by a plurality of input and output lines; 

using dimensions of the said multidimensional space as cell location parameters to identify a 
cell's location in the multidimensional global memory space; 

using the said cell location parameters to assign a location for incoming cells in the global 
memory space; 
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using the said cell location parameters for routing and switching purposes in a switching 
apparatus; 

using the said cell location parameters or a subset of coordinates of the multidimensional 
memory space, for creating self-routing parameters for the purpose of incoming cells* switching through 
a switching apparatus; 

using a pointer, called the Sliding- Window pointer to identify a set of memory locations in the 
multidimensional global memory space to write the incoming cells to, and read outgoing cells from; 

using switch cycle to update the said Sliding- Window pointer parameters in order for the 
Sliding* Window pointer to identify, in a newer switch cycle, a newer set of memory locations to write the 
incoming cells to and read the outgoing cells from the global multidimensional memory space; 

using a set of parameters to identify the said Sliding- Window pointer; 

using one subset of parameters for the said Sliding- Window pointer to identify a group of 
memory locations in the multidimensional memory space as the qualifying set of memory addresses to 
write the incoming cells to or read the outgoing cells from; 

using another subset of parameters for the said Sliding- Window pointer to identify the qualifying 
addresses within the said group of memory locations identified by previous subset of parameters to write 
the incoming cells to and read the outgoing cells from; 

using the said Sliding-Window pointer parameters to keep track of qualifying set of memory 
locations in the global memory space and to compute write addresses to be used for storing the incoming 
cells in a plurality of said memory modules of the switching apparatus; 

using the said Sliding-Window pointer parameters to keep track of qualifying set of memory 
locations in the global memory space and to compute read addresses to be used for reading the outgoing 
cells from a plurality of said memory modules of the switching apparatus. 

14. The method of assignment of said self-routing parameters of claim 13 further comprising the steps of: 
using counters to keep the current value of the said Sliding-Window pointers; 
using counters to keep track of length of queues of cells destined to a plurality of said output 

lines; 

using counters to keep track of location parameters of the last cell in the queues of cells destined 
to a plurality of said output lines; 

using a multidimensional array to keep track of the state of the multidimensional memory space 
comprising of all the cell locations in a plurality of said memory modules of the switching apparatus. 
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